<template>
  <div>
  <!-- 一条文章单元格 -->
  <van-cell :to="`/article?aid=${item.art_id}`">
    <!-- 标题区域的插槽 -->
    <template #title>
      <div class="title-box">
        <!-- 标题 -->
        <span>{{ item.title }}</span>
        <!-- 单图 -->
        <img
        v-if="item.cover.images"
        v-show="item.cover.type === 1"
        class="thumb"
        v-lazy="item.cover.images[0]" />
      </div>
      <!-- 三张图片 -->
      <div
      class="thumb-box"
      v-show="item.cover.type === 3">
        <img
        v-for="(item, i) in item.cover.images"
        :key="i"
        class="thumb"
        v-lazy="item" />
      </div>
    </template>
    <!-- label 区域的插槽 -->
    <template #label>
      <div class="label-box">
        <div>
          <span>{{ item.aut_name }}</span>
          <span>{{ item.comm_count }}评论</span>
          <span>{{ $timeAgo(item.pubdate) }}</span>
        </div>
        <!-- 反馈按钮 -->
        <van-icon name="cross" @click.stop="show1 = true" v-if="showCross" />
        <!-- 一级反馈 -->
        <van-action-sheet
        v-model="show1"
        :actions="actions1"
        @select="onSelect"
        get-container="body"
        cancel-text="取消" />
        <!-- 二级反馈 -->
        <van-action-sheet
        v-model="show2"
        :actions="actions2"
        @select="onSelect"
        get-container="body"
        cancel-text="返回" />
      </div>
    </template>
  </van-cell>
  </div>
</template>

<script>
import { dislikeArticle, reportArticle } from '@/api/article'
export default {
  name: 'ArticleItem',
  props: {
    item: {
      type: Object,
      required: true
    },
    // 控制反馈按钮的 × 是否显示
    showCross: {
      type: Boolean,
      default: true
    }
  },
  data () {
    return {
      show1: false,
      show2: false,
      actions1: [{ name: '不感兴趣', id: 1 }, { name: '反馈垃圾内容', id: 2 }],
      actions2: [
        { name: '其他问题' },
        { name: '标题夸张' },
        { name: '低俗色情' },
        { name: '错别字多' },
        { name: '旧文重复' },
        { name: '内容不实' },
        { name: '侵权' },
        { name: '涉嫌违法犯罪' },
        { name: '广告软文' }
      ]
    }
  },
  methods: {
    // 反馈选择的时候
    async onSelect ({ id }, index) {
      // action：当前点击的action对象
      // index：action对象在数组中的下标
      if (id === 1) {
        try {
          // 点击不感兴趣，调接口发请求（通知服务器）
          await dislikeArticle(this.item.art_id)
          // 通知父组件从数组中删除指定 id 文章
          this.$emit('dislike', this.item.art_id)
          // 给出成功的提示
          this.$toast.success('感谢反馈')
        } catch (e) {
          // 给出失败的提示
          this.$toast.fail('反馈失败')
        }
      } else if (id === 2) {
        // 反馈垃圾内容
        // 显示二级反馈
        this.show2 = true
      } else {
        try {
        // 二级反馈
        // 调接口发请求
          await reportArticle(this.item.art_id, index, '')
          // 关闭一级二级反馈面板
          this.show1 = this.show2 = false
          // 给出成功的提示
          this.$toast.success('举报成功')
        } catch (e) {
          this.$toast.fail('举报失败')
        }
      }
    }
  }
}
</script>

<style scoped lang="less">
/* 标题样式 */
.title-box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

/* label描述样式 */
.label-box {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/* 文章信息span */
.label-box span{
  margin: 0 3px;
  &:first-child{
    margin-left: 0;
  }
}

/* 图片的样式, 矩形黄金比例：0.618 */
.thumb {
  width: 113px;
  height: 70px;
  background-color: #f8f8f8;
  object-fit: cover;}

// 三图, 图片容器
.thumb-box {
  display: flex;
  justify-content: space-between;
}
</style>
